from django.shortcuts import render

# Create your views here.
from rest_framework.views import APIView
from .utils import OauthQQ
from rest_framework.response import Response
from oauth.models import OAuthQQUser
from rest_framework_jwt.settings import api_settings
from .serializers import OauthQQSerializer
# Create your views here.
class QQAuthURLView(APIView):
    """
    实现出现QQ授权登录视图
    GET /oauth/qq/statues/
    """



    def get(self,request):

        # 生成auth_url
        # https://graph.qq.com/oauth2.0/authorize
        # 请求参数请包含如下内容：
        # response_type   必须      授权类型，此值固定为“code”。
        # client_id       必须      申请QQ登录成功后，分配给应用的appid。
        # redirect_uri    必须      成功授权后的回调地址，必须是注册appid时填写的主域名下的地址，建议设置为网站首页或网站的用户中心。注意需要将url进行URLEncode。
        # state           必须      client端的状态值。用于第三方应用防止CSRF攻击，成功授权后回调时会原样带回。请务必严格按照流程检查用户与state参数状态的绑定。
        # scope              可选      scope=get_user_info

        #获取state
        state = request.query_params.get('state')

        qq = OauthQQ()

        auth_url = qq.get_oauth_url(state)

        return Response({'auth_url':auth_url})

class OauthQQView(APIView):

    """
    GET         通过code 获取token
    """

    def get(self,request):

        # 拼接url
        # PC网站：https://graph.qq.com/oauth2.0/token
        # GET
        # grant_type      必须      授权类型，在本步骤中，此值为“authorization_code”。
        # client_id       必须      申请QQ登录成功后，分配给网站的appid。
        # client_secret   必须      申请QQ登录成功后，分配给网站的appkey。
        # code            必须      上一步返回的authorization
        # redirect_uri    必须      与上面一步中传入的redirect_uri保持一致。

        # 0. 获取code
        code = request.query_params.get('code')

        if code is None:
            return Response(status=400)

        qq = OauthQQ()

        access_token = qq.get_access_token(code)

        openid = qq.get_openid(access_token)

        # 根据openid来判断 用户是否绑定过
        # 如何判断呢?
        try:
            qquser = OAuthQQUser.objects.get(openid=openid)
        except OAuthQQUser.DoesNotExist:
            # 第一次授权 我们需要绑定

            token = OAuthQQUser.genericte_openid_token(openid)
            # aaaaaaa
            return Response({'access_token': token})
        else:
            # 已经绑定过了, 直接登录,返回token
            # 生成已登录的token
            jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER
            jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER
            user = qquser.user
            payload = jwt_payload_handler(user)
            token = jwt_encode_handler(payload)

            response = Response({
                'token': token,
                'user_id': user.id,
                'username': user.username
            })

            return response

    def post(self, request):

        """
        当用户提交的时候 把手机号,密码,短信验证码,和 access_token(openid) 提交给后台
        后台对 短信验证码进行验证, 在验证 access_token , 验证token之后可以提前到openid
        把入库
        """

        # 创建序列化器
        serialzier = OauthQQSerializer(data=request.data)

        # 进行校验
        serialzier.is_valid(raise_exception=True)

        # 数据保存
        user = serialzier.save()

        # 返回登录的token

        # 生成已登录的token
        jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER
        jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER

        payload = jwt_payload_handler(user)
        token = jwt_encode_handler(payload)

        response = Response({
            'token': token,
            'user_id': user.id,
            'username': user.username
        })

        return response


